草庐IT

postgresql - 在 docker 环境中重启 postgres

全部标签

go - Docker 在完成 Golang 项目构建之前退出

我正在尝试使用Docker构建一个Golang项目,但该过程在完成之前一直退出,这是终端输出的一部分:github.com/kataras/go-template(download)Fetchinghttps://golang.org/x/crypto/acme/autocert?go-get=1Parsingmetatagsfromhttps://golang.org/x/crypto/acme/autocert?go-get=1(statuscode200)get"golang.org/x/crypto/acme/autocert":foundmetatagmain.metaImp

postgresql - 如何在 golang 中使用 .Format 将 time.Time 对象转换为格式化字符串?

我目前正在尝试从我的SQL数据库中获取一个time.Time对象,并将检索到的值转换为格式化字符串,如下所示:TIME_FORMAT:="%Y-%m-%dT%H:%M:%S"这是我在Python中用来做同样事情的格式,但我知道它不适合go。我已经从数据库中获取了值,现在只需要对其进行格式化。请注意,我已将ccc.Ia_date定义为interface{}类型,因为数据库中的此值可能为空。这是我的代码片段:fmt.Println(reflect.TypeOf(ccc.Ia_date))//givesmetime.Timet:=ccc.Ia_date//whichprintsas:2016

batch-file - 在下一个批处理脚本运行中使用由批处理脚本设置的环境变量

实际上我想运行2个bat脚本,第一个脚本将设置一个系统变量setNEWPATH="E:/Some"第二个脚本将显示该变量的路径:echo%NEWPATH%。这不是第一次使用同一台服务器,当我重新启动将显示路径的服务器时,否则它将不显示任何内容。那么有人可以帮助我吗? 最佳答案 我没有完全理解你的问题,但这里有一些观察结果。一些理论在批处理文件(由shell进程cmd.exe执行)或任何其他类型的进程中设置的环境变量只能为设置正是这个过程。也就是说,每个进程都有一个特殊的block,其中包含在创建该进程时由操作系统提供给它的环境变量。

go - Go Server无需重启的无缝补丁部署

我很好奇是否有任何解决方案可以部署go服务器而无需将其关闭并重新启动。我知道ASP.Net和PHP等流行的解决方案可以为用户session无缝执行此操作。无状态session会处理这个问题吗? 最佳答案 即使是最简单的应用程序服务器也可以通过引入请求路由器(例如nginx)来实现这种无缝部署。或haproxy.这两个路由器都允许您将请求转发到不同的服务(称为反向代理),并在不断开连接的情况下重新加载它们的配置。举个例子:将您的路由器配置为监听0.0.0.0.80并将这些请求转发到127.0.0.1:5001。在127.0.0.1:5

bash - 无法从GoLang中的/etc/profile获取环境变量

我在/etc/profile中设置了一些环境变量,我可以从bash访问它们,但由于某些原因我无法从Go中获取它们。/etc/配置文件:...TEST_ENV=test_me我可以从bash访问它:echo$TEST_ENVtest_me我无法从GO访问这个变量os.Getenv("TEST_ENV")//returns""如果我列出可用的环境变量os.Environ()我没有看到我正在寻找的变量,但有一些变量可能会有所帮助:SHELL=/bin/shUSER=rootLOGNAME=root我猜我的问题与不同的session和shell有关,所以我什至尝试运行exec.Command(

ubuntu - 在 Docker 容器 (Ubuntu) 中运行在 Windows 中创建的 Go 应用程序

我创建了一个非常简单的应用程序来输出一些文本。我的开发环境是Windows+DockerforWindows。我创建了ubuntu容器,并在Windows中为ubuntu构建了我的应用程序setGOARCH=amd64setGOOS=linuxgobuild-o"myapp"然后我将“myapp”文件复制到共享文件夹,并在我的容器的共享文件夹中看到它。在我尝试在容器中运行它但出现错误之后为什么我不能运行它?它是构建不正确还是我尝试以某种错误的方式执行它?在Windows中,当我运行我的exe文件时我有这个输出,我想要在Ubuntu中有相同的东西。更新按照建议,我尝试./myapp并且出

postgresql - 如何从go app查看postgresql "raise notice"

我正在用go编写小应用程序。现在我需要在应用程序控制台中记录postgres“raisenotice”消息。我没有找到postgresql在*sql.Conn中引发消息的地方(我使用go/sql和lib/pq驱动程序)例子,createfunctionshow_mes()returnsintas$$beginraisenotice'testmessagefrompg';return1;end$$languageplpgsql;我从goapp调用这个函数并可以得到结果。但是我如何从goapp访问消息“来自pg的测试消息”?在用Node编写的当前版本中,我们在控制台中记录消息以进行调试:谢

postgresql - golang/pq pq : operator does not exist: bigint = text

query:="WITHb(ColA,ColB)AS(VALUES($1,$2))UPDATEschema_name.table_nameASaSETColC=b.ColBFROMbWHEREa.ColA=b.ColAANDa.ColB=b.ColB"res,err:=db.Exec(query,1,1)上述代码失败并出现以下错误:pq:operatordoesnotexist:bigint=text“ColC”是BIGINT类型。根据我的调查,驱动程序将值作为文本而不是整数插入。问题:https://github.com/lib/pq/issues/582

testing - echo c.Get ("user") 在测试环境中不起作用

我正在尝试测试基于echo框架/路由器构建的golangAPI。我有以下测试......funcTestLogout(t*testing.T){loadConfig()db:=stubDBs(t)Convey("Whenyoupostto/logout",t,func(){Convey("withavalidtoken,youshouldgetaasuccessmsgandbeloggedout",func(){e:=echo.New()e.Use(middleware.JWTWithConfig(middleware.JWTConfig{SigningKey:[]byte("secr

sql - 向 postgres 查询添加查询参数时出错

当我写代码时:err:=database.QueryRow("SELECTpage_title,page_content,page_dateFROMpagesWHEREid=1").Scan(&thisPage.Title,&thisPage.Content,&thisPage.Date)一切正常。但我希望它不只是获取带有id=1的页面,而是动态的。所以我写:err:=database.QueryRow("SELECTpage_title,page_content,page_dateFROMpagesWHEREid=?",pageID).Scan(&thisPage.Title,&th